<template>
  <u-popup
      :closeOnClickOverlay="closeOnClickOverlay"
      :customStyle="{
			backgroundColor: 'rgb(214, 218, 220)'
		}"
      :overlay="overlay"
      :popup="false"
      :safeAreaInsetBottom="safeAreaInsetBottom"
      :show="show"
      :zIndex="zIndex"
      mode="bottom"
      @close="popupClose"
  >
    <view class="u-keyboard">
      <slot/>
      <view
          v-if="tooltip"
          class="u-keyboard__tooltip"
      >
        <view
            :hover-stay-time="100"
            hover-class="u-hover-class"
        >
          <text
              v-if="showCancel"
              class="u-keyboard__tooltip__item u-keyboard__tooltip__cancel"
              @tap="onCancel"
          >{{ showCancel && cancelText }}
          </text>
        </view>
        <view>
          <text
              v-if="showTips"
              class="u-keyboard__tooltip__item u-keyboard__tooltip__tips"
          >{{ tips ? tips : mode == 'number' ? '数字键盘' : mode == 'card' ? '身份证键盘' : '车牌号键盘' }}
          </text>
        </view>
        <view
            :hover-stay-time="100"
            hover-class="u-hover-class"
        >
          <text
              v-if="showConfirm"
              class="u-keyboard__tooltip__item u-keyboard__tooltip__submit"
              hover-class="u-hover-class"
              @tap="onConfirm"
          >{{ showConfirm && confirmText }}
          </text>
        </view>
      </view>
      <template v-if="mode == 'number' || mode == 'card'">
        <u-number-keyboard
            :dotDisabled="dotDisabled"
            :mode="mode"
            :random="random"
            @backspace="backspace"
            @change="change"
        ></u-number-keyboard>
      </template>
      <template v-else>
        <u-car-keyboard
            :autoChange="autoChange"
            :random="random"
            @backspace="backspace"
            @change="change"
        ></u-car-keyboard>
      </template>
    </view>
  </u-popup>
</template>

<script>
import props from './props.js';

/**
 * keyboard 键盘
 * @description 此为uViw自定义的键盘面板，内含了数字键盘，车牌号键，身份证号键盘3中模式，都有可以打乱按键顺序的选项。
 * @tutorial https://www.uviewui.com/components/keyboard.html
 * @property {String}      mode        键盘类型，见官网基本使用的说明 （默认 'number' ）
 * @property {Boolean}      dotDisabled      是否显示"."按键，只在mode=number时有效 （默认 false ）
 * @property {Boolean}      tooltip        是否显示键盘顶部工具条 （默认 true ）
 * @property {Boolean}      showTips      是否显示工具条中间的提示 （默认 true ）
 * @property {String}      tips        工具条中间的提示文字，见上方基本使用的说明，如不需要，请传""空字符
 * @property {Boolean}      showCancel      是否显示工具条左边的"取消"按钮 （默认 true ）
 * @property {Boolean}      showConfirm      是否显示工具条右边的"完成"按钮（ 默认 true ）
 * @property {Boolean}      random        是否打乱键盘按键的顺序 （默认 false ）
 * @property {Boolean}      safeAreaInsetBottom  是否开启底部安全区适配 （默认 true ）
 * @property {Boolean}      closeOnClickOverlay  是否允许点击遮罩收起键盘 （默认 true ）
 * @property {Boolean}      show        控制键盘的弹出与收起（默认 false ）
 * @property {Boolean}      overlay        是否显示遮罩 （默认 true ）
 * @property {String | Number}  zIndex        弹出键盘的z-index值 （默认 1075 ）
 * @property {String}      cancelText      取消按钮的文字 （默认 '取消' ）
 * @property {String}      confirmText      确认按钮的文字 （默认 '确认' ）
 * @property {Object}      customStyle      自定义样式，对象形式
 * @event {Function} change 按键被点击(不包含退格键被点击)
 * @event {Function} cancel 键盘顶部工具条左边的"取消"按钮被点击
 * @event {Function} confirm 键盘顶部工具条右边的"完成"按钮被点击
 * @event {Function} backspace 键盘退格键被点击
 * @example <u-keyboard mode="number" v-model="show"></u-keyboard>
 */
export default {
  name: "u-keyboard",
  data() {
    return {}
  },
  mixins: [uni.$u.mpMixin, uni.$u.mixin, props],
  methods: {
    change(e) {
      this.$emit('change', e);
    },
    // 键盘关闭
    popupClose() {
      this.$emit('close');
    },
    // 输入完成
    onConfirm() {
      this.$emit('confirm');
    },
    // 取消输入
    onCancel() {
      this.$emit('cancel');
    },
    // 退格键
    backspace() {
      this.$emit('backspace');
    }
  }
}
</script>

<style lang="scss" scoped>
@import "../../libs/css/components.scss";

.u-keyboard {

  &__tooltip {
    @include flex;
    justify-content: space-between;
    background-color: #FFFFFF;
    padding: 14px 12px;

    &__item {
      color: #333333;
      flex: 1;
      text-align: center;
      font-size: 15px;
    }

    &__submit {
      text-align: right;
      color: $u-primary;
    }

    &__cancel {
      text-align: left;
      color: #888888;
    }

    &__tips {
      color: $u-tips-color;
    }
  }
}
</style>
